草庐IT

Java TCP Socket等待空闲?

全部标签

javascript - 如何找到等待 promise 的 JavaScript 代码

我们有一个相当复杂的JavaScript异步系统。JavaScript库中的所有函数都设计为异步的。我们主要使用AngularJS延迟对象,一些部分使用jQuery(不过我们不会将它们混在一起——即Angular代码等待Angular延迟promise)。我们遇到的问题是代码在启动时似乎“挂起”,5次中有2次。缓存JS代码和promise解析的时间似乎有问题。似乎没有任何工具或任何东西可以指出发生挂起时有问题的代码正在等待什么。如何找到等待promise的JavaScript代码?谢谢。 最佳答案 所以错误实际上最终与promise

javascript - 如何实现 Typescript 异步等待模式 : Where is the Promise

我正在学习Angular和Typescript。我有一个客户服务,在这个服务中我有一个方法,我希望从RESTfull服务返回一组客户。最初我是这样创建我的GetCustomers函数的:publicGetCustomers():Dtos.ICustomer[]{var_customers:Dtos.ICustomer[];this._httpService.get('http://localhost/myTestApi/api/customers/').success(function(data){_customers=dataasDtos.ICustomer[];}).error(f

JavaScript - 同步等待异步操作(休眠)

我知道这里被问过很多次,也回答过很多次,这不是应该如何完成的方式,但再一次:)是否有可能以某种方式调用异步函数(例如计时器/ajax调用),基本上是常见的异步任务并同步等待直到它结束而不会出现100%CPU使用率和浏览器阻塞?简单的回答就足够了——是或否。如果不是,我必须根据“异步方式”中的异步操作编写所有代码,否则会更好;)想象一下:updateCSS("someurl.css")functionupdateCSS(url){varcss=getCachedResource(url);css=css.replace(/regexp/gm,function(curUrl){base64

javascript - $timeout 仍然是等待 Angular 指令模板的最佳实践吗?

我们团队等待指令模板呈现的设计模式是将我们的DOM操作代码包装在$timeout中(在指令的链接函数内),我曾经知道这是正常的设计模式。这仍然是正确的,还是有更好/更安全的设计模式来做到这一点?模式示例在ECMAScript6中:link:($scope,$element)=>{$timeout(()=>{vardomElementFromTemplate=$element.find('myDOMElement');}} 最佳答案 当您尝试选择DOM中可用的元素时:IMO从来都不是最佳实践,因为不需要为同步dom选择函数创建异步行为

javascript - 检查 GoogleMap Canvas 元素是否已经空闲

我的问题很直接。google.maps.event.addListenerOnce(map,'idle',function(){//code});这段代码将在map当前忙缩放或平移后触发。不是在它已经闲置的时候。有没有办法在if语句中检查Canvas的状态?因此,当它已经空闲时,您将在不添加监听器的情况下执行//code? 最佳答案 没有记录map的空闲状态信号的属性,但您可以自己实现它。假设您在map初始化后立即调用它:google.maps.event.addListener(map,'idle',function(){this

javascript - 如何等待异步方法的回调返回值?

我知道等待一个异步方法是愚蠢的,oneshouldusecallbacksinstead.但是,如果第三方API强制您同步怎么办?我正在开发一个Chrome扩展程序,它将阻止用户访问已在另一个选项卡中打开的网站。我基本上需要根据打开的选项卡中的url取消请求。我想用chrome.webRequest.onBeforeRequest像这样:functiononBeforeRequest(details){varwebsiteAlreadyOpenInOtherTab;//Hereiwanttoset`websiteAlreadyOpenInOtherTab`byusingthe`chro

javascript - 等待 sendKeys() 的 Protractor

在使用AngularJS构建的Web表单中,我尝试将一些数据输入组合框,然后通过按下箭头键和Enter键选择一个值。之后,我检查组合框的弹出窗口(它是一个KendoUI组合框)是否不再可见。测试在Windows和MacOSX上的Chrome中运行。在Windows上,以下代码运行良好:comboInput.sendKeys('CAN').sendKeys(protractor.Key.ENTER).sendKeys(protractor.Key.ARROW_DOWN).sendKeys(protractor.Key.ENTER);expect(input.getAttribute('v

javascript - 如何在 Gulp 4 中使用异步/等待?

我正在尝试做这样的事情:gulp.task("test",async()=>{returngulp.src("**/*.scss").pipe(print((filePath)=>`File:${filePath}`));});(打印为gulp-print)但它给出了以下内容:[22:08:43]Starting'test'...[22:08:43]Finished'test'after12ms[22:08:43]File:src\app\styles\app.scss[22:08:43]File:src\app\styles\test.scss即它在打印消息之前完成。我正在使用Gul

javascript - Typescript/ES7 中异步/等待的有限并行性

我一直在尝试使用Typescript,但我现在对如何有效使用async/await有点困惑。我正在向数据库中插入一堆记录,我需要获取每次插入返回的ID列表。下面的简化示例一般有效,但它并不像我想要的那样优雅,而且它完全是顺序的。asyncfunctiongeneratePersons(){constnames=generateNames(firstNames,lastNames);letids=[]for(letnameofnames){constid=awaitdb("persons").insert({first_name:name.firstName,last_name:name

Javascript 如何通过解构将 promise.spread 语法迁移到异步/等待

我正在清理一些sequelize代码,findOrCreate函数返回一个需要展开才能获得实际结果对象的promise。我想重写我的代码以使用await代替,并且鉴于ES6支持数组解构,我认为用它代替User.findOrCreate({where:{mcId},defaults}).spread((user,created)=>{//dostuff})我能做到const[user,created]=awaitUser.findOrCreate({where:{mcId},defaults})但事实并非如此。我收到错误(intermediatevalue)isnotiterable执行